<?
	/* Se asegura que el archivo es incluido por el index */
		defined( 'LOAD_MODULE_ACTION' ) or die( 'No esta permitido el acceso directo a ' . __FILE__ );
	/* Cuando se hace el include del archivo automaticamente crea un objeto y lo guarda en una variable temporal */
		$this->oTmpObject = new Modelo_frm( $this );

	class Modelo_frm extends Frm
	{
	function setValue ( $ncModelo )
		{
			$cSql = "SELECT ncModelo, cdModelo, ncMarca, ncMarca, ncTipoProducto, nqVelocidad, nqEspacio, nqTamano
								FROM atModelo
								WHERE ncModelo = $ncModelo";
			$aRow = $this->oDatabase->getArray($cSql);
			$this->setFieldsArray ( $aRow );
			return $aRow;
		}
	function Modelo_frm( &$oModule )
		{
			$this->Frm( $oModule );
			//Crea los Objetos de los campos de edicion
			$this->aFields['ncModelo']			= new Input( "Codigo", "ncModelo", '', false, true );
			$this->aFields['cdModelo']			= new InputText( "Nombre", "cdModelo" );
			$this->aFields['ncMarca']				= new InputList( "Marca", "ncMarca" );
			$this->aFields['ncTipoProducto']	= new InputList( "Tipo", "ncTipoProducto" );
			$this->aFields['nqVelocidad']		= new InputNumber( "Velocidad", "nqVelocidad" );
			$this->aFields['nqEspacio']			= new InputNumber( "Espacio", "nqEspacio" );
			$this->aFields['nqTamano']			= new InputNumber( "Tamano", "nqTamano" );
		}
	function setLevel( $nLevel)
		{
			switch ( $nLevel )
			{
				case 2:
					$ncTipoProducto = $this->aFields['ncTipoProducto']->getValue();
					if ( $ncTipoProducto )
					{
						$cSql = "SELECT bVelocidad, bEspacio, bTamano FROM acTipoProducto WHERE ncTipoProducto = $ncTipoProducto";
						list ( $bVelocidad, $bEspacio, $bTamano ) = $this->oDatabase->getArray($cSql);
					}
					$this->aInput = array( 'ncModelo', 'cdModelo' , 'ncMarca', 'ncTipoProducto' );
					if ( $bVelocidad ) $this->aInput[] = "nqVelocidad";
					if ( $bEspacio ) $this->aInput[] = "nqEspacio";
					if ( $bTamano ) $this->aInput[] = "nqTamano";
					break;
					break;
			}
		}
	function initializeForm()
		{
			// Configura el Titulo
			$this->setLabel( "Modelo" );
			if ( $this->isRetrievable() &&  $this->aFields['ncModelo']->getValue() )
			{
				$aRow = $this->setValue ( $this->aFields['ncModelo']->getValue() );
			}
			return true;
		}
	function initializeField( $cField , &$oField )
		{
			switch ( $cField )
			{
				case 'cdModelo':
				// Configura el Nombre
					$oField->setMandatory( $this->isMandatory() );
					$oField->setLength(40);
				break;
				case 'ncTipoProducto':
					$cSql = "SELECT ncTipoProducto, cdTipoProducto FROM acTipoProducto";
					$oField->setMatrix ( $this->oDatabase->getMatrix( $cSql ) );
					$oField->setOnChangeAutoSubmit( $this );
				break;
				case 'ncMarca':
					$cSql = "SELECT ncMarca, cdMarca FROM atMarca";
					$oField->setMatrix ( $this->oDatabase->getMatrix( $cSql ) );
				break;
				case 'nqVelocidad':
				case 'nqTamano':
				case 'nqEspacio':
					$oField->setLength(8.2);
				break;
			}
		}
	}
?>